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METHOD FOR A GENERAL NEAR OPTIMAL TURBO 
CODE TRELLIS TERMINATION 

This applications claims benefit of U.S. 
Provisional Application Serial No. 60/098,111, filed 
August 27, 1998. 

BACKGROUND OF THE INVENTION 

The present invention relates to methods for 
terminating both of the constituent encoders of a turbo 
code and developing puncturing patterns applicable at a 
trellis termination stage that ensures the same number of 
transmitted bits for each trellis stage during the 
information bit transmission and trellis termination 
stages • 

The process of forward and reverse link turbo 
encoding and decoding, specifically for Code Division 
Multiple Access (CDMA) communications channels, is 
thoroughly described in copending U.S. Patent Application 
Serial No. 09/248,338 (Attorney Docket No. PD-980024) of 
Eroz, et al., for SETS OF RATE-COMPATIBLE UNIVERSAL TURBO 
CODES NEARLY OPTIMIZED OVER VARIOUS RATES AND INTERLEAVER 
DELAYS, filed 2/11/99, and copending United States Patent 
Application Serial No. 09/235,582, (Attorney Docket No. 
PD-980163) of Eroz, et al., for FORWARD ERROR CORRECTION 
SCHEME FOR DATA CHANNELS USING UNIVERSAL TURBO CODE, 
filed 1/22/99, both of which are incorporated herein by 
reference. 

In a convolutional encoding scheme, tail bits 
are inserted after information bits, to zero out all 
shift registers of an encoder. For feed forward encoders, 
tail bits are equal to zero. For feedback encoders the 
value of tail bits depend on the contents of the shift 
register current values. 

A turbo encoder consists of a parallel ^ 
concatenation of two (2) or more recursive (feedback) 
convolutional encoders. Because each constituent encoder 
processes the information bits in a different order due 
to a turbo interleaver, it is not possible to terminate 
all constituent encoders by the same tail bits. 



A trellis termination method general enough to 
be used for a set of turbo codes with different code 
rates as in the third generation CDMA systems is 
desirable. Included in the desirable general method is a 
method of puncturing tail bit sequences. 

SUMMARY OF THE INVENTION 

The present invention advantageously addresses 
the needs above as well as other needs by providing a 
method and apparatus for a general Turbo Code trellis 
termination which may be employed when a turbo encoder 
operates within a wide range of turbo code rates when 
transmitting information bits. 

In its most general form, the invention can be 
characterized as a method of terminating two or more 
constituent encoders of a turbo encoder. The method 
comprises the steps of: generating tail input bits at 
each of two or more constituent encoders, including the 
step of deriving the tail input , bits from each of the two 
or more constituent encoders separately from the contents 
of shift registers within each of the two or more 
constituent encoders, after an encoding of information 
bits by the two or more constituent encoders; and 
puncturing one or more tail output bits such that 1/R 
tail output bits are transmitted for each of a plurality 
of trellis stages, wherein R is a turbo code rate 
employed by the turbo encoder during the information bit 
transmission. 

In yet another variation, the step of 
puncturing the one or more tail output bits further 
comprises the step of: transmitting, during trellis 
termination, the tail output bits only if they are sent 
from an output branch of one of the two or more 
constituent encoders that is used during information bit 
transmission. 



BRIEF DESCRIPTION OF THE DRAWINGS 

The above and other aspects, features and 
advantages of the present invention will be more apparent 
from the following more particular description thereof, 
5 presented in conjunction with the following drawings 
wherein: 

FIG. 1 is a block diagram of a turbo encoder 
with interleaved bits entering a second encoder, for use 
in accordance with one embodiment of the present 
10 invention. 

Corresponding reference characters indicate 
corresponding components throughout the several views of 
the drawings. 

Ms 

O 15 DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

fy 

y The following description of the presently 

in contemplated best mode of practicing the invention is not 

to be taken in a limiting sense, but is made merely for 
B the purpose of describing the general principles of the 

^. 20 invention. The scope of the invention should be 
LI determined with reference to the claims. 

2 Referring to FIG. 1, an exemplary turbo code 

^ encoder is shown wherein one embodiment of a Turbo Code 

trellis termination design terminates one encoder 10 (a 
25 first encoder) while disabling another encoder ip' (a 
second encoder) and at a different time terminates the 
other encoder 10* (second encoder) while disabling the 
encoder 10 (first encoder) . 

The encoders (first and second encoders) 10, 10' 
30 of the turbo code encoder of FIG. 1 are constituent 

encoders configured in a parallel concatenation. It is 
well known in the art that a constituent encoder employ ia 
configuration of modular adders 17, 20, 26, 28, 30, 24, 
and 25, and shift registers 18, 21, 22, coupled through 
35 nodes (such as node 32) to produce output bits, including 
tail output bits, X(t) , Yo(t) , Yi(t) , for example, 
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depending upon the encoding scheme. FIG. 1 is just one 
example of such a parallel concatenation of constituent 
encoders, wherein an interleaver device (Inter leaver) 16 
is employed between an input for X(t) and the second 
encoder 10', and wherein additionally, a puncturer 3 6 is 
employed, switchably coupled to respective encoder 
outputs for each of the encoders (first and second 
encoders) 10, 10'. As described herein, tail input bits 
will mean the bits X, and X' in FIG. 1, and tail output 
bits will mean the bits X, X', Yo, Yo', Yi or Y^', In other 
turbo encoders, there may be more than two constituent 
encoders. Each of the constituent encoders may utilize 
a fewer or greater number of shift registers than in 
FIG. 1. 

In FIG. 1, after message bits X(t) are encoded, 
a switch 12 is moved to a feedback position to allow the 
generation of three (3) consecutive tail input bits, in 
this example, generated from the contents of each of 
three shift reglst:ers 18, 21, and 22 (also referred to 
herein as a first shift register 18, a second shift 
register 21^ and a third shift register 22) • In general, 
a number of tail input bits X(t) , X'(t) for terminating a 
constituent encoder is equal to a number of shift 
registers in that encoder. 

At the end of each clock cycle, new tail input 
bits X(t) , X*(t) are generated for zeroing out each 
respective shift register of the three shift registers, 
18, 21 and 22. 

In one embodiment of the irivention the encoders 
10, 10' are terminated simultaneottsly within three clock 
cycles, each with its own taij^nput bit X(t) , X'(t) . 
Alternatively > the first encoder 10 is first terminated 
while the second encoder ylO' is disabled, followed by the 
second encoder 10' beincr terminated while the firsts 
encoder 10 is disablejd. 
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In the variation with the encoders 10, 10* 
terminated at different tiroes the encoders 10, 10' can be 
terminated in consecutive clock cycles, wherein six (6) 
consecutive clock cycle tail input bits X(t) , X*(t) , 
5 consecutively terminate both the encoders 10, 10'. 

As can be seen from FIG. 1, a second tail input 
bit sequence 34' for terminating the second encoder 10' is 
fed back into the second encoder 10* through a switch 12' 
and circuit 14'. Tail input bits X(t) , X'(t) are not 
10 interleaved by the turbo interleaver 16. Similarly, a 
tail input bit sequence 34 for terminating the first 
encoder 10 is fed back into the first encoder 10 through 
another switch 12 and another circuit 14. 
U The zeroing of the shift registers liB, 21, 22, 

O 15 prior to implementing a puncturing scheme per an 
jjl embodiment of the invention, is triggered by a beginning 

^ and an ending tail input bit sequence X(t) , X'(t), each 

sequence having a number h of tail input bits X(t) , X'(t) 
3 equal to the number h of shift registers 18, 21, 22 or 

20 18', 21, 22 coupled to each one of the encodiers 10, 10'. 
Ll As with information and coded bits, tail output 

g bits X, Yo, Yi, X", Yo, Yi' are also punctured by the 

2 puncturer 36. 

Table 1 indicates associated tail output bit 
25 puncturing patterns having indicator sequences (e.g., 

"Ill 000") identifying which bits to puncture and which 
bits to transmit. The indicator sequence, comprising 
"l"'s or "0"'s is selected in accordance with an encoder 
rate. In this notation, "1" indicates the tail output bit 
30 should be transmitted and "0" indicates that the tail 
output should be punctured. Certain entries in Table 1 
are labeled "repeat", which means that transmitted bits 
are transmitted twice. 

The tail input bit sequences 34, 34', which 
35 comprise tail input bits X, and X', are generated after 
the encoders 10, 10' encode the information bits with the 
switches 12, 12' (FIG.l), while the switches 12, 12' are in 
an up position. The first n/R tail output bits Xi, Yo, 



5 



Yi, Wherein n is the number of shift registers 18^ 21, 22 
or 18', 21', 22' per constituent encoder (n=3 in FIG.l), 
and wherein R is a turbo code rate being employed, are 
generated by clocking the first encoder 10 n times with 
5 its switch 12 in the down position while the second 

encoder 10' is not clocked, and puncturing or repeating 
the resulting tail output bits Xi, Yo, Yi, X', Yo*, 
according to Table 1 below. The last n/R tail output 
bits X',Yo*,Yi' are generated by clocking the second encoder 
10 10' n timer with its switch 12' in the down position while 
the first encoder 10 is not clocked, and puncturing or 
repeating the resulting tail output bits according to 
^ Table 1. These final output bits are denoted by X", Yo' or 

Yi" 

5 15 rate % turbo codes, th^ tail output bits 

in fdr each of a first n tail input b^t (also referred to 

m herein as "the beginning tail b;kt sequence X(t) ") are XYq, 

."S and the tail output bits for efach of a last n tail bit 

5 periods (al.so referred to h^ein as "the ending tail bit 

^= 20 sequence X'(t)") are X'Yo'. y^or rate 1/3 turbo codes, the 
U tail output bits for each of the first n tail input bits 

2 are XXYo, and the tail /output bits for each of the last n 

2 tail bits are X'X'Yq*. /For a rate 1/4 turbo code, the tail 

output bits for eacl/ of the first n tail input bits are 
25 XXYqYi and the tail /output bits for each of the last n 

tail input bits periods are X'X'Yq'Yi'. 

Tail inputs bits are not interleaved by the 

interleaver 16. They are added after the encoding of the 

information bits. 



6 



TABLE 1: Puncturing Patterns for Tail Output Bits 



Rate 


1/2 


1/3 


1/4 


X(t) 


111 000 


111 000 
Repeat 


111 000 
Repeat 


Yo(t) 


111 000 


111 000 


111 000 


Yi(t) 


000 000 


000 000 


111 000 










X'(t) 


000 111 


000 111 
Repeat 


000 111 
Repeat 


Yo'(t) 


000 111 


000 111 


000 111 


Yi'(t) 


000 000 


000 000 


000 111 



When employing Table 1 to design puncturing 
patterns for tail output bits, the row designation 
"Repeat" means that for a rate 1/3 or a rate 1/4 turbo 
code^ when transmitted, the bits X and X* are transmitted 
twice. 

For a rate 1/2 turbo code, the puncturing table 
is read first from top to bottom, and then from left to 
right. For a rate 1/3 turbo code and a rate 1/4 turbo 
code, the puncturing table is read first from top to 
bottom, repeating X(t) and X'(t), and then from left to 
right. 

The puncturing patterns in Table 1 are chosen 

so that: 

(1) A number of transmitted tail output bits 
during trellis termination is 1/R for each trellis branch 
wherein R is the turbo code rate employed during 
information bit transmission. Advantageously, this 
condition ensures that the same turbo code rate is used 
for trellis termination as for information bit 
transmission. 

(2) Only output branches of the encoders— 10, 10' 
used during information bit transmission are used for 
trellis termination. For example, for rate 1/2 and rate 





1/3 turbo coders^ only X(t) , X'(t) , Yo(t:) and Yo(t:) are 
transmitted during information bit transmission; Yi(t) 
and Y'i(t) are always punctured. Therefore, only X(t) , . 
X'(t), Yo(t) and Yo(t) are transmitted during the trellis 
5 termination stage, as well. Advantageously, therefore, 
if a manufacturer only wanted to implement a rate 1/2 and 
encoder, such a manufacturer would only have to implement 
transmissions of bits from branches X, Yq or X*, Yq'. 

(3) In order to meet conditions (1) and (2) , it 

10 may require repetition of some tail output bits during 
trellis termination. That is, to both keep the turbo 
code rate the same, and to only use output branches used 
in information bit transmission, it may be necessary to 
repeat one or more of the tail bits for each encoder 10, 

15 10' in order to keep the turbo code rate the same. 

In the preferred embodiment illustrated by 
Table 1, X(t) and X'(t) are selected to be repeated in 
both the turbo code rate 1/3 and rate 1/4 cases. Table 1 
may also be employed irrespective of whether the encoders 

20 10, 10' are terminated concurrently or non-concurrent ly. 

Alternative embodiments are envisioned, in 
keeping within the spirit of the invention wherein 
another tail output bit is selected to be repeated, such 
as, for example that corresponding to Yo(t) and Yo'(t) . 

25 Alternatively, where a code rate lower than 1/4 

is employed it may be necessary to repeat more than one 
tail output bit per encoder 10, 10', in which case an 
additional tail bit besides X(t) may be repeated, such as 
repeating X(t) and Yo(t) or repeating X(t) twice or any 

30 combination whatsoever. 

While the invention herein disclosed has been 
described by means of specific embodiments and 
applications thereof, numerous modifications and 
variations could be made thereto by those skilled in the 

35 art without departing from the scope of the invention set 
forth in the claims. 
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